<template>
  <div>
    <div id="app" class="wrapper wrapper-content">
      <div class="row">
          <div>
              <div class="panel panel-primary">
                  <div class="panel-body" style="padding: 0px 120px; box-sizing: border-box;">
                      <el-form size="small" :model="inputForm" ref="inputForm" v-loading="loading" :disabled="formReadOnly">
                          <div  style="text-align:center">
                              <h3 style="font-weight: bold;color: black;font-size:24px">离职申请单</h3>
                          </div>
                          <table style="margin:0 auto;width:80%;margin-top:20px;border-collapse: collapse;margin-bottom:20px">
                              <tr style="line-height: 3.5;">
                                  <td colspan="4"
                                      style="font-weight: bold;text-align: left;padding-left: 32px;position: relative;font-size: 14px">
                                      <img src="../../../../../assets/imgs/processManagement/work.png" alt=""
                                          style="position: absolute;width: 20px;height: 20px;left: 0px;top: 14px;margin-left: 8px">
                                      基本信息
                                  </td>
                              </tr>
                              <tr class="iconHidden">
                                  <td class="width-15">申请人</td>
                                  <td class="width-30" >
                                      <el-form-item  prop="applyuser.id" >
                                            <user-select :limit='1' :value="inputForm.applyuser.id" @getValue='(value) => {inputForm.applyuser.id=value}' disabled></user-select>
                                      </el-form-item> 
                                  </td>
                                  <td class="width-15" >所属公司</td>
                                  <td class="width-30"  >
                                      <el-form-item  prop="company.id">
                                        <SelectTree
                                          ref="company"
                                          :props="{
                                              value: 'id',             // ID字段名
                                              label: 'name',         // 显示名称
                                              children: 'children'    // 子级字段名
                                            }"
                                          disabled
                                          url="/sys/office/treeData?type=2"
                                          :value="inputForm.company.id"
                                          :clearable="true"
                                          :accordion="true"
                                          @getValue="(value) => {inputForm.company.id=value}"/>
                                      </el-form-item>
                                  </td>
                              </tr>
                              <tr  class="iconHidden">
                                  <td class="width-15">申请时间</td>
                                  <td class="width-30">
                                      <el-form-item prop="applydate" >
                                          <el-date-picker
                                            v-model="inputForm.applydate"
                                            type="datetime"
                                            style="width: 100%;"
                                            disabled
                                            value-format="yyyy-MM-dd HH:mm:ss"
                                            :clearable="false"
                                            placeholder="请选择">
                                          </el-date-picker>
                                      </el-form-item>
                                  </td>
                                  <td class="width-15">所属部门</td>
                                  <td class="width-30">
                                      <el-form-item  prop="depart.id">
                                        <SelectTree
                                          ref="depart"
                                          :props="{
                                              value: 'id',             // ID字段名
                                              label: 'name',         // 显示名称
                                              children: 'children'    // 子级字段名
                                            }"
                                          disabled
                                          url="/sys/office/treeData?type=2"
                                          :value="inputForm.depart.id"
                                          :clearable="true"
                                          :accordion="true"
                                          @getValue="(value) => {inputForm.depart.id=value}"/>
                                      </el-form-item>   
                                  </td>
                              </tr>
                              <tr style="line-height: 3.5;">
                                  <td colspan="4"
                                      style="font-weight: bold;text-align: left;padding-left: 32px;position: relative;font-size: 14px">
                                      <img src="../../../../../assets/imgs/processManagement/basic.png" alt=""
                                          style="position: absolute;width: 20px;height: 20px;left: 0px;top: 14px;margin-left: 8px">
                                      离职信息
                                  </td>
                              </tr>
                              <tr class="iconHidden">
                                  <td class="width-15"><span style="color: red">*&nbsp;</span>离职原因</td>
                                  <td class="width-30">3
                                      <el-form-item  prop="reson" :rules="[{required: true, message:'离职原因不能为空', trigger:'blur'}]">
                                          <el-input  v-model="inputForm.reson"  ></el-input>
                                      </el-form-item>
                                  </td>
                                  <td class="width-15"><span style="color: red">*&nbsp;</span>工作交接</td>
                                  <td class="width-30">
                                      <el-form-item  prop="handover" :rules="[{required: true, message:'工作交接不能为空', trigger:'blur'}]">
                                          <el-input  v-model="inputForm.handover"  ></el-input>
                                      </el-form-item>
                                  </td>
                              </tr>
                              <tr class="iconHidden">
                                  <td class="width-15"><span style="color: red">*&nbsp;</span>入职日期</td>
                                  <td class="width-30">
                                      <el-form-item  prop="incomedate"  :rules="[{required: true, message:'入职日期不能为空', trigger:'blur'}]">
                                        <el-date-picker
                                              v-model="inputForm.incomedate"    
                                              style="width: 100%;"
                                              type="date"
                                              value-format="yyyy-MM-dd"                                          
                                              format="yyyy-MM-dd"
                                              @change="timeCondition"
                                              placeholder="请选择">
                                            </el-date-picker>
                                      </el-form-item>
                                  </td>
                                  <td class="width-15"><span style="color: red">*&nbsp;</span>离岗日期</td>
                                  <td class="width-30">
                                      <el-form-item  prop="quitdate" :rules="[{required: true, message:'离岗日期不能为空', trigger:'blur'}]">
                                            <el-date-picker
                                                  type="date"
                                                  v-model="inputForm.quitdate"
                                                  style="width: 100%;"
                                                  value-format="yyyy-MM-dd"                                               
                                                  format="yyyy-MM-dd"
                                                  @change="timeCondition"
                                                  placeholder="请选择">
                                                </el-date-picker>
                                      </el-form-item>
                                  </td>
                              </tr>
                              <tr class="iconHiddens">
                                  <td class="width-15">交接人员</td>
                                  <td class="width-30">
                                      <el-form-item  prop="acceptuser.id">
                                          <user-select :limit='1' :value="inputForm.acceptuser.id" @getValue='(value) => {inputForm.acceptuser.id=value}' readonly  ></user-select>
                                      </el-form-item>
                                  </td>
                                  <td class="width-15">未处理事宜</td>
                                  <td class="width-30">
                                    <el-form-item prop="undelthings">
                                      <el-input  v-model="inputForm.undelthings" ></el-input>
                                    </el-form-item>
                                  </td>
                              </tr>
                          </table>
                      </el-form>                
                  </div>
              </div>
          </div>
      </div>
    </div>
  </div>
</template>
<script>
  import UserSelect from '@/components/userSelect'
  import SelectTree from '@/components/treeSelect/treeSelect.vue'
  import tableStyles from '../../../../../utils/mixins'
  export default {
    mixins: [tableStyles],
    data () {
      return {
        title: '',
        method: '',
        loading: false,
        inputForm: {
          id: '',
          applyuser: {
            id: ''
          },
          company: {
            id: ''
          },
          applydate: '',
          depart: {
            id: ''
          },
          reson: '',
          handover: '',
          incomedate: '',
          quitdate: '',
          acceptuser: {
            id: ''
          },
          undelthings: '',
          remarks: ''
        },
      }
    },
    props: {
      businessId: {
        type: String,
        default: ''
      },
      formReadOnly: {
        type: Boolean,
        default: false
      }
    },
    components: {
      UserSelect,
      SelectTree
    },
    watch: {
      'businessId': {
        handler (newVal) {
          if (this.businessId) {
            this.init(this.businessId)
          } else {
            this.$nextTick(() => {
              this.$refs.inputForm.resetFields();
              if(this.$store.state.user.id!=''){
                var users=this.$store.state.user
              }else{
                var users=JSON.parse(sessionStorage.getItem("userInfo"));
              }
              this.inputForm.applyuser.id=users.id;
              this.inputForm.company.id=users.company.id;
              this.inputForm.depart.id=users.office.id;
              this.inputForm.applydate=this.getNowTime();
            })
          }
        },
        immediate: true,
        deep: false
      }
    },
    created(){
      window.addEventListener("beforeunload",()=>{
        sessionStorage.setItem("userInfo",JSON.stringify(this.$store.state.user))
      })
    },
    methods: {
      //时间选择的判断条件
      timeCondition(){
        if(this.inputForm.incomedate.length!=0&&this.inputForm.quitdate.length!=0){
          var startDate=new Date(this.inputForm.incomedate);
          var endDate=new Date(this.inputForm.quitdate);
          if(startDate>endDate){
            this.$message.warning('入职日期不能大于离岗日期');
            this.inputForm.quitdate='';
            return false
          }  
        }
      },

      init (id) {
        if (id) {
          this.loading = true
          this.inputForm.id = id
          this.$nextTick(() => {
            this.$refs.inputForm.resetFields()
            this.$http({
              url: `/dlyrl/oa/applyquit/applyQuit/queryById?id=${this.inputForm.id}`,
              method: 'get'
            }).then(({data}) => {
              this.inputForm = this.recover(this.inputForm, data.applyQuit)
              this.loading = false; 
            })
          })
        }
      },
      // 表单提交
      saveForm (callback) {
        this.$refs['inputForm'].validate((valid) => {
          if (valid) {
            this.loading = true
            this.$http({
              url: `/dlyrl/oa/applyquit/applyQuit/save`,
              method: 'post',
              data: this.inputForm
            }).then(({data}) => {
              if (data && data.success) {
                callback(data.businessTable, data.businessId);
                this.loading = false;
                 this.$refs.inputForm.resetFields();
                this.inputForm.applyuser.id=this.$store.state.user.id;
                this.inputForm.company.id=this.$store.state.user.company.id;
                this.inputForm.depart.id=this.$store.state.user.office.id;
                this.inputForm.applydate= this.getNowTime();
              }
            })
          }
        })
      }
    }
  }
</script>